草庐IT

python - Alembic 迁移卡在 postgresql 上?

全部标签

ruby-on-rails - 升级到 Yosemite 10.10 后无法连接到 postgresql 数据库

更新到Yosemite10.10后,我无法连接到我的postgresql数据库。我运行Rails控制台并尝试获取第一个用户,但出现此错误...>➜game_golfgit:(master)✗railsc>Loadingdevelopmentenvironment(Rails4.1.4)>[1]pry(main)>User.first>PG::ConnectionBad:couldnotconnecttoserver:Connectionrefused>Istheserverrunningonhost"localhost"(::1)andaccepting>TCP/IPconnectio

ruby-on-rails - 从 schema.rb 生成迁移文件

我希望从schema.rb生成一个迁移文件。是否可以?目前我有很多迁移文件,想将所有内容合并到一个主迁移文件中。我还认为我可能在某个时候不小心删除了一个迁移文件。谢谢你的帮助 最佳答案 您可以将schema.rb复制并粘贴到迁移中并回溯它(例如更改日期),这样现有的数据库就不会运行它。创建此迁移后,您可以删除所有旧迁移。我不同意Andrew不应该删除迁移的观点。迁移总是基于模型类的变化而意外中断,修复它们非常重要。由于我确定您正在使用版本控制,因此如果您需要它们以供引用,您可以随时回顾历史。

ruby-on-rails - Rails 迁移 : tried to change the type of column from string to integer

我使用railsgeneratemigrations命令在我的rails应用程序中创建了一个表。这是迁移文件:classCreateListings然后我想将纬度和经度存储为整数我试着跑:railsgeneratemigrationchangeColumnType该文件的内容是:classChangeColumnType我原以为列类型会发生变化,但是rake被中止并出现了以下错误消息。我想知道为什么这没有通过?我在我的应用程序中使用postgresql。rakedb:migrate==ChangeColumnType:migrating=========================

ruby-on-rails - 迁移 : t. 引用不允许指定索引名称

我在迁移中有以下内容:create_table:model_with_a_long_namedo|t|t.references:other_model_with_an_equally_long_name,index:trueend对于Postgres,这会产生一个名称太长的索引。有没有办法手动指定索引名称(不用单独添加整数列和索引)?类似下面的内容:create_table:model_with_a_long_namedo|t|t.references:other_model_with_an_equally_long_name,index:true,index_name:'model_

ruby - bundle 失败 - 找不到 PostgreSQL 客户端库 (libpq)

这个问题在这里已经有了答案:Can'tfindthePostgreSQLclientlibrary(libpq)(23个回答)关闭7年前。我想我已经尝试了我能找到的关于这个问题的所有建议。仍然不适合我。当我尝试bundle...$bundle...Gem::Installer::ExtensionBuildError:ERROR:Failedtobuildgemnativeextension./System/Library/Frameworks/Ruby.framework/Versions/2.0/usr/bin/rubyextconf.rbcheckingforpg_config.

ruby-on-rails - 在 postgresql 应用程序的 rails 中运行迁移后的序列通知

当我在postgresql上的Rails应用程序中运行我的迁移时,我得到了以下通知NOTICE:CREATETABLEwillcreateimplicitsequence"notification_settings_id_seq"forserialcolumn"notification_settings.id"NOTICE:CREATETABLE/PRIMARYKEYwillcreateimplicitindex"notification_settings_pkey"fortable"notification_settings"我的迁移文件包含088_create_notificati

ruby - Ruby 中有类似 Python 生成器的东西吗?

我是Ruby的新手,有没有办法从Ruby函数中yield值?如果是,如何?如果不是,我有哪些选择来编写惰性代码? 最佳答案 Ruby的yield关键字与同名的Python关键字非常不同,所以不要被它混淆。Ruby的yield关键字是调用与方法关联的block的语法糖。最接近的等效项是Ruby的Enumerator类。例如,Python的等价物:defeternal_sequence():i=0whileTrue:yieldii+=1这是:defeternal_sequenceEnumerator.newdo|enum|i=0whil

ruby-on-rails - 使用 'gem pq' 安装 PostgreSQL gem 失败并出现错误 : Failed to build gem native extension

我正在学习RubyonRails并尝试开发应用程序。在我的应用程序中,我试图在开发模式下使用默认的SQLite数据库,在生产模式下使用PostgreSQL。但是我在尝试使用安装pggem时遇到以下错误:geminstallpgBuilding native extensions.  This could take a while...ERROR:  Error installing pg:        ERROR: Failed to build gem native extension.     /home/tusharkhatiwada/.rvm/rubies/ruby-2.0.

python生成矩阵为何[[0 for i in range(n)] for j in range(m)]而不能[[0]*n]*m

python生成矩阵,使用[[0]*n]*m,我们会发现,当改变其中某一个元素时,整列数据都会发生改变,而使用[[0foriinrange(n)]forjinrange(m)]才可以生成正常的矩阵。这是因为,list是可变元素,而int是不可变元素,对于list存储采用指针,引用型变量,改变矩阵其中某一个元素值,导致所有行的这个位置的元素都会改变。下面具体分析:1、python列表的存储形式Python列表和C语言数组不同,并不是存的实在的值,而是存放的只想其他实例的指针。所以也就能够理解为什么python列表里里面什么东西都可以放进去而不需要考虑类型了~2、[0]*2的存储形式这里的0是同一

ruby-on-rails - Rails 4 迁移 : how to reorder columns

我了解到add_column有一个:after选项来设置插入列的位置。太糟糕了,我才知道它:在添加了一堆之后。如何编写迁移以简单地对列进行重新排序? 最佳答案 当使用MySQL时,您可以调用change_column,但是您必须重复列类型(只需从您的其他迁移中复制并粘贴它):defupchange_column:your_table,:some_column,:integer,after::other_columnend或者如果您必须对一个表中的多个列重新排序:defupchange_table:your_tabledo|t|t.c